home *** CD-ROM | disk | FTP | other *** search
/ Amiga Plus 2002 #11 / Amiga Plus CD - 2002 - No. 11.iso / Tools / Development / PowerD / Pdmod / modules / netinet / ip.m < prev    next >
Encoding:
Text File  |  2002-10-28  |  6.6 KB  |  183 lines

  1. /*
  2.  * $Id: ip.h,v 1.4 1993/06/30 05:45:25 jraja Exp $
  3.  *
  4.  * HISTORY
  5.  * $Log: ip.h,v $
  6.  * Revision 1.4  1993/06/30  05:45:25  jraja
  7.  * Changed bitfield definitions to be more like ANSI-C.
  8.  *
  9.  * Revision 1.3  1993/03/05  03:20:01  ppessi
  10.  * Compiles with SASC. Initial test version.
  11.  *
  12.  * Revision 1.2  93/03/03  21:39:09  21:39:09  jraja (Jarno Tapio Rajahalme)
  13.  * Added #ifdef to prevent multiple inclusion.
  14.  * 
  15.  * Revision 1.1  92/11/17  16:29:25  16:29:25  jraja (Jarno Tapio Rajahalme)
  16.  * Initial revision
  17.  * 
  18.  *
  19.  */
  20.  
  21. /*
  22.  * Copyright (c) 1982, 1986 Regents of the University of California.
  23.  * All rights reserved.
  24.  *
  25.  * Redistribution and use in source and binary forms, with or without
  26.  * modification, are permitted provided that the following conditions
  27.  * are met:
  28.  * 1. Redistributions of source code must retain the above copyright
  29.  *    notice, this list of conditions and the following disclaimer.
  30.  * 2. Redistributions in binary form must reproduce the above copyright
  31.  *    notice, this list of conditions and the following disclaimer in the
  32.  *    documentation and/or other materials provided with the distribution.
  33.  * 3. All advertising materials mentioning features or use of this software
  34.  *    must display the following acknowledgement:
  35.  *      This product includes software developed by the University of
  36.  *      California, Berkeley and its contributors.
  37.  * 4. Neither the name of the University nor the names of its contributors
  38.  *    may be used to endorse or promote products derived from this software
  39.  *    without specific prior written permission.
  40.  *
  41.  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  42.  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  43.  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  44.  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  45.  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  46.  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  47.  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  48.  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  49.  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  50.  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  51.  * SUCH DAMAGE.
  52.  *
  53.  *      @(#)ip.h        7.10 (Berkeley) 6/28/90
  54.  */
  55.  
  56. /*
  57.  * Definitions for internet protocol version 4.
  58.  * Per RFC 791, September 1981.
  59.  */
  60. //MODULE 'netinet/in'
  61.  
  62. #define IPVERSION       4
  63.  
  64. /*
  65.  * Structure of an internet header, naked of options.
  66.  *
  67.  * We declare ip_len and ip_off to be short, rather than u_short
  68.  * pragmatically since otherwise unsigned comparisons can result
  69.  * against negative integers quite easily, and fail in subtle ways.
  70.  */
  71.  
  72. #define IP_DF $4000                    /* dont fragment flag */
  73. #define IP_MF $2000                    /* more fragments flag */
  74.  
  75. OBJECT ip
  76.     ip_v:UBYTE,                 /* version */
  77.     ip_hl:UBYTE,                /* header length */
  78.     ip_tos:UBYTE,                 /* type of service */
  79.     ip_len:WORD,                 /* total length */
  80.     ip_id:UWORD,                  /* identification */
  81.     ip_off:WORD,                 /* fragment offset field */
  82.     ip_ttl:UBYTE,                 /* time to live */
  83.     ip_p:UBYTE,                   /* protocol */
  84.     ip_sum:UWORD,                 /* checksum */
  85.     ip_src:in_addr,
  86.     ip_dst:in_addr               /* source and dest address */
  87.  
  88.  
  89.  
  90. #define IP_MAXPACKET    65535           /* maximum packet size */
  91.  
  92. /*
  93.  * Definitions for IP type of service (ip_tos)
  94.  */
  95. #define IPTOS_LOWDELAY          $10
  96. #define IPTOS_THROUGHPUT        $08
  97. #define IPTOS_RELIABILITY       $04
  98.  
  99. /*
  100.  * Definitions for IP precedence (also in ip_tos) (hopefully unused)
  101.  */
  102. #define IPTOS_PREC_NETCONTROL           $e0
  103. #define IPTOS_PREC_INTERNETCONTROL      $c0
  104. #define IPTOS_PREC_CRITIC_ECP           $a0
  105. #define IPTOS_PREC_FLASHOVERRIDE        $80
  106. #define IPTOS_PREC_FLASH                $60
  107. #define IPTOS_PREC_IMMEDIATE            $40
  108. #define IPTOS_PREC_PRIORITY             $20
  109. #define IPTOS_PREC_ROUTINE              $10
  110.  
  111. /*
  112.  * Definitions for options.
  113.  */
  114. #define IPOPT_COPIED(o)         ((o) & $80)
  115. #define IPOPT_CLASS(o)          ((o) & $60)
  116. #define IPOPT_NUMBER(o)         ((o) & $1f)
  117.  
  118. #define IPOPT_CONTROL           $00
  119. #define IPOPT_RESERVED1         $20
  120. #define IPOPT_DEBMEAS           $40
  121. #define IPOPT_RESERVED2         $60
  122.  
  123. #define IPOPT_EOL               0               /* end of option list */
  124. #define IPOPT_NOP               1               /* no operation */
  125.  
  126. #define IPOPT_RR                7               /* record packet route */
  127. #define IPOPT_TS                68              /* timestamp */
  128. #define IPOPT_SECURITY          130             /* provide s,c,h,tcc */
  129. #define IPOPT_LSRR              131             /* loose source route */
  130. #define IPOPT_SATID             136             /* satnet id */
  131. #define IPOPT_SSRR              137             /* strict source route */
  132.  
  133. /*
  134.  * Offsets to fields in options other than EOL and NOP.
  135.  */
  136. #define IPOPT_OPTVAL            0               /* option ID */
  137. #define IPOPT_OLEN              1               /* option length */
  138. #define IPOPT_OFFSET            2               /* offset within option */
  139. #define IPOPT_MINOFF            4               /* min value of above */
  140.  
  141. /*
  142.  * Time stamp option structure.
  143.  */
  144. OBJECT ip_timestamp
  145.     ipt_code:UBYTE,               /* IPOPT_TS */
  146.     ipt_len:UBYTE,                /* size of structure (variable) */
  147.     ipt_ptr:UBYTE,                /* index of current entry */
  148.     ipt_oflw:UBYTE,             /* overflow counter */
  149.     ipt_flg:UBYTE,              /* flags, see below */
  150.     [CUNION
  151.         ipt_time[1]:ULONG,
  152.         ipt_ta:ipt_ta_x
  153.     ENDUNION]:ipt_timestamp
  154.  
  155. OBJECT ipt_ta_x
  156.     ipt_addr:in_addr,
  157.     ipt_time:ULONG
  158.  
  159. /* flag bits for ipt_flg */
  160. #define IPOPT_TS_TSONLY         0               /* timestamps only */
  161. #define IPOPT_TS_TSANDADDR      1               /* timestamps and addresses */
  162. #define IPOPT_TS_PRESPEC        3               /* specified modules only */
  163.  
  164. /* bits for security (not byte swapped) */
  165. #define IPOPT_SECUR_UNCLASS     $0000
  166. #define IPOPT_SECUR_CONFID      $f135
  167. #define IPOPT_SECUR_EFTO        $789a
  168. #define IPOPT_SECUR_MMMM        $bc4d
  169. #define IPOPT_SECUR_RESTR       $af13
  170. #define IPOPT_SECUR_SECRET      $d788
  171. #define IPOPT_SECUR_TOPSECRET   $6bc5
  172.  
  173. /*
  174.  * Internet implementation parameters.
  175.  */
  176. #define MAXTTL          255             /* maximum time to live (seconds) */
  177. #define IPFRAGTTL       60              /* time to live for frags, slowhz */
  178. #define IPTTLDEC        1               /* subtracted when forwarding */
  179.  
  180. #define IP_MSS          576             /* default maximum segment size */
  181.  
  182.  
  183.